gsk: Fix serialization of cairo node
authorUmang Jain <mailumangjain@gmail.com>
Wed, 4 Oct 2017 21:02:02 +0000 (02:32 +0530)
committerUmang Jain <mailumangjain@gmail.com>
Sun, 8 Oct 2017 12:52:34 +0000 (18:22 +0530)
https://bugzilla.gnome.org/show_bug.cgi?id=788534

gsk/gskrendernodeimpl.c

index d560d8a5549de4aa54a353493b28de0cf340074c..13fbd0024bb63e5dbb408c6c2035b62a7464775b 100644 (file)
@@ -1746,9 +1746,31 @@ gsk_cairo_node_serialize (GskRenderNode *node)
     }
   else
     {
-      /* FIXME: implement! */
-      g_assert_not_reached ();
-      return NULL;
+      int width, height;
+      int stride, i;
+      guchar *mem_surface, *data;
+
+      width = cairo_image_surface_get_width (self->surface);
+      height = cairo_image_surface_get_height (self->surface);
+      stride = cairo_image_surface_get_stride (self->surface);
+      data = cairo_image_surface_get_data (self->surface);
+
+      mem_surface = (guchar *) g_malloc (width * height * 4);
+
+      for (i = 0; i < height; i++)
+        memcpy (mem_surface + i * width * 4, data + i * stride, width * 4);
+
+      return g_variant_new ("(dddduu@au)",
+                            (double) node->bounds.origin.x, (double) node->bounds.origin.y,
+                            (double) node->bounds.size.width, (double) node->bounds.size.height,
+                            (guint32) width,
+                            (guint32) height,
+                            g_variant_new_fixed_array (G_VARIANT_TYPE ("u"),
+                                                       mem_surface,
+                                                       width * height,
+                                                       sizeof (guint32)));
+
+      g_free (mem_surface);
     }
 }